<template>
  <div class="app-container">
    医院设置列表
    <!-- 条件查询 -->
    <el-form :inline="true" class="demo-form-inline">
      <el-form-item>
        <el-input v-model="searchObj.hosName" placeholder="医院名称" />
      </el-form-item>
      <el-form-item>
        <el-input v-model="searchObj.hosCode" placeholder="医院编号" />
      </el-form-item>
      <el-button type="primary" icon="el-icon-search" @click="getList()"
        >查询</el-button
      >
    </el-form>
    <!-- 工具条 -->
    <div>
      <el-button type="danger" size="mini" @click="removeRows()"
        >批量删除</el-button
      >
    </div>
    <!-- 医院列表 -->
    <el-table
      :data="list"
      stripe
      style="width: 100%"
      @selection-change="handleSelectionChange"
    >
      <el-table-column type="selection" width="55" />
      <el-table-column type="index" width="50" label="序号" />
      <el-table-column prop="hosName" label="医院名称" />
      <el-table-column prop="hosCode" label="医院编号" />
      <el-table-column prop="apiUrl" label="api基础路径" width="200" />
      <el-table-column prop="contactsName" label="联系人姓名" />
      <el-table-column prop="contactsPhone" label="联系人手机" />
      <el-table-column label="状态" width="80">
        <template slot-scope="scope">
          {{ scope.row.status === 1 ? "可用" : "不可用" }}
        </template>
      </el-table-column>
      <el-table-column label="操作" width="280" align="center">
        <template slot-scope="scope">
          <el-button
            type="danger"
            size="mini"
            icon="el-icon-delete"
            @click="removeDataById(scope.row.id)"
            >删除</el-button
          ><el-button
            v-if="scope.row.status === 1"
            type="danger"
            size="mini"
            icon="el-icon-unlock"
            @click="lockHospSet(scope.row.id, 0)"
            >锁定</el-button
          >
          <el-button
            v-if="scope.row.status === 0"
            type="success"
            size="mini"
            icon="el-icon-lock"
            @click="lockHospSet(scope.row.id, 1)"
            >解锁</el-button
          >
          <router-link :to="'/hospSet/edit/' + scope.row.id">
            <el-button type="primary" size="mini" icon="el-icon-edit">
              编辑</el-button
            >
          </router-link>
        </template>
      </el-table-column>
    </el-table>
    <!-- 分页 -->
    <el-pagination
      :current-page="current"
      :page-size="limit"
      :total="total"
      style="padding: 30px 0; text-align: center"
      layout="total, prev, pager, next, jumper"
      @current-change="getList"
    />
  </div>
</template>

<script>
// 引入接口定义的js文件
import hospset from "@/api/hospset.js";
export default {
  // 定义变量和初始化
  data() {
    return {
      current: 1, // 当前页
      limit: 3, // 每页记录数
      searchObj: {}, // 条件封装对象
      list: [], // 每页数据集合
      total: 0, // 总记录数
      multipleSelection: [], // 批量选择中选择的记录列表
    };
  },
  // 在页面渲染之前执行
  created() {
    this.getList(); // 一般调用methods定义的方法，得到数据
  },
  // 定义方法，进行请求接口调用
  methods: {

    // 锁定和取消锁定
    lockHospSet(id, status) {
      hospset.lockHospSet(id, status).then((response) => {
        // 刷新
        this.getList(this.current);
      });
    },
    // 获取复选框的id值
    handleSelectionChange(selection) {
      this.multipleSelection = selection;
    },
    // 批量删除方法
    removeRows() {
      this.$confirm("此操作将永久删除医院设置信息, 是否继续?", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      })
        .then(() => {
          //确定执行then方法
          var idList = [];
          // 遍历数组，得到id值，设置到idList中
          this.multipleSelection.forEach((element) => {
            var id = element.id;
            idList.push(id);
          });
          //调用接口
          hospset.batchRemoveHosptalSet(idList).then((response) => {
            //提示
            this.$message({
              type: "success",
              message: "删除成功!",
            });
            //刷新页面
            this.getList(this.current);
          });
        })
        .catch(() => {
          this.$message({
            type: "info",
            message: "已取消删除",
          });
        });
    },
    // 医院设置列表
    getList(page = 1) {
      // 添加当前页的参数
      this.current = page;
      hospset
        .getHospSetList(this.current, this.limit, this.searchObj)
        .then((response) => {
          // 请求成功返回的数据
          // 返回集合赋值list
          this.list = response.data.records;
          // 总记录数
          this.total = response.data.total;
          console.log(response);
        }) // 请求成功调用
        .catch(error => {
          //请求失败错误信息
          console.log(error);
        }); // 请求失败调用
    },
    // 删除医院设置的方法
    removeDataById(id) {
      this.$confirm("此操作将永久删除医院设置信息, 是否继续?", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      })
        .then(() => {
          //确定执行then方法
          //调用接口
          hospset.deleteHospSet(id).then((response) => {
            //提示
            this.$message({
              type: "success",
              message: "删除成功!",
            });
            //刷新页面
            this.getList(this.current);
          });
        })
        .catch(() => {
          this.$message({
            type: "info",
            message: "已取消删除",
          });
        });
    },
  },
};
</script>